为SQLite3提供一个ANSI到UTF8的互转函数
在使用Sqlite3时必须要用到的
使用方法:
charIT之家 src = "...";//待转换的ANSI或UTF8字符串
charIT之家 dst = NULL;//保存由函数内部分配的内存指针, 不需要传入内存缓冲区的
转换为UTF-8:to_utf8(src, &dst);
转换为ANSI:to_gb(src, &dst);
返回值:零 - 失败, 非零 - 成功.
注意:如果操作成功, 需要手动释放函数内部分配的空间:
复制代码 代码如下:
if(dst)
{
free(dst);
dst = NULL;
}
代码:
复制代码 代码如下:
#include <windows.h>
#include <stdio.h>int to_utf8(charIT之家 psrc, charIT之家IT之家 ppdst)
{
int ret,ret2;
wchar_tIT之家 pws = NULL;
charIT之家 putf = NULL;
ret = MultiByteToWideChar(CP_ACP, 0, psrc, -1, NULL, 0);
if(ret<=0){
IT之家ppdst = NULL;
return 0;
}
pws = (wchar_tIT之家)malloc(retIT之家2);
if(!pws){
IT之家ppdst = NULL;
return 0;
}
MultiByteToWideChar(CP_ACP, 0, psrc, -1, pws, ret);
ret2 = WideCharToMultiByte(CP_UTF8, 0, pws, -1, NULL, 0, NULL, NULL);
if(ret2<=0){
free(pws);
return 0;
}
putf = (charIT之家)malloc(ret2);
if(!putf){
free(pws);
return 0;
}
if(WideCharToMultiByte(CP_UTF8, 0, pws, ret, putf, ret2, NULL, NULL)){
IT之家ppdst = putf;
free(pws);
return 1;
}else{
free(pws);
free(putf);
IT之家ppdst = NULL;
return 0;
}
}
int to_gb(charIT之家 psrc, charIT之家IT之家 ppdst)
{
int ret, ret2;
wchar_tIT之家 pws = NULL;
charIT之家 pgb = NULL;
ret = MultiByteToWideChar(CP_UTF8, 0, psrc, -1, NULL, 0);
if(ret<=0){
IT之家ppdst = NULL;
return 0;
}
pws = (wchar_tIT之家)malloc(retIT之家2);
if(!pws){
IT之家ppdst = NULL;
return 0;
}
MultiByteToWideChar(CP_UTF8, 0, psrc, -1, pws, ret);
ret2 = WideCharToMultiByte(CP_ACP, 0, pws, -1, NULL, 0, NULL, NULL);
if(ret2<=0){
free(pws);
return 0;
}
pgb = (charIT之家)malloc(ret2);
if(!pgb){
free(pws);
IT之家ppdst = NULL;
return 0;
}
if(WideCharToMultiByte(CP_ACP, 0, pws, -1, pgb, ret2, NULL, NULL)){
IT之家ppdst = pgb;
free(pws);
return 1;
}else{IT之家ppdst = 0;
free(pgb);
free(pws);
return 0;
}
}
相关热词:
本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!
本文地址: https://v30.fanwenzhu.com/sql/sqlite/8700.shtml
相关文章
热门TAG
win10 ecshop 主机 阿里云 解决 配置 C# C++ 解析 SQL语句 命令 Go语言 方法 CSS3 HTML5 CSS win7 MSSQL 服务器配置 IIS7.5 IIS7 IIS6 IIS CentOS 7 Linux oracle数据库 oracle phpcms discuz discuz教程最新文章
-
sqlite只通过文件锁就可以
时间:2021-01-23
-
返回的是一个SQLiteDatabas
时间:2021-01-23
-
只不过它是OC方式封装了
时间:2021-01-23
-
应该增加autoincrementcreate
时间:2021-01-23
-
如果没有就从Bundle中把数
时间:2021-01-23
-
Linux 部署ASP.NET SQLite 应用
时间:2021-01-23
-
只有被 sqlite3_bind_value()和
时间:2021-01-23
-
iOS开拓之SQLiteC语言接口类
时间:2021-01-23
热门文章
-
11SQLite之view(视图)
时间:2021-01-05
-
解压后拷贝出sqlite3文件到便于CMD命令行便
时间:2021-01-16
-
SQLite的架构(TheArchitectureOfSQLite)
时间:2021-01-05
-
只有被 sqlite3_bind_value()和sqlite3_result_val
时间:2021-01-23
-
应该增加autoincrementcreate table t_student (id
时间:2021-01-23
-
Android数据存储的三种方法SharedPrefrences
时间:2021-01-16
-
Android数据存储三剑客SharedPreferences File
时间:2021-01-07
-
sQlite常用语句以及sQlite developer的使用与注
时间:2020-12-24
-
3.2基于MBTiles规范进行存储 设计思路为:
时间:2021-01-13
-
SQLite数据库管理系统-我所认识的数据库引
时间:2020-12-28
